<template>
  <section class="msite">
    <!--首页头部-->
       <!-- 搜索框头部用slot技术  接受文本用props -->
    <!-- 第三步使用组建替换掉HTML代码 -->
    <HeaderTop :title="address.name">   <!--  用强制绑定  绑定address对象的name属性  进行读数据操作-->
    <router-link class="header_search" slot="left" to="/search">
       <i class="iconfont icon-sousuo"></i>
    </router-link>
    <router-link class="header_login" slot="right" :to="userInfo._id ? '/userinfo': '/login'">
        <span class="header_login_text" v-if="!userInfo._id">
          登录|注册
        </span>
        <span class="header_login_text" v-else>
           <i class="iconfont icon-person"></i>
        </span>
      </router-link>
    </HeaderTop>
    <!--首页导航-->
    <nav class="msite_nav">
      <div class="swiper-container" v-if="categorys.length">
        <div class="swiper-wrapper">
          <div class="swiper-slide" v-for="(categorys, index) in categorysArr" :key="index">
             <!-- v-for="(categorys, index) in categorysArr" :key="index" -->
                <a href="javascript:" class="link_to_food" v-for="(category, index) in categorys" :key="index">
                   <!-- v-for="(category, index) in categorys" :key="index" -->
              <div class="food_container">
                <img :src="baseImageUrl+category.image_url" />
              </div>
              <span>{{category.title}}</span>
            </a>
          </div>
        </div>
        <!-- Add Pagination -->
        <div class="swiper-pagination"></div>
      </div>
      <img src="./images/msite_back.svg" alt="" v-else>
    </nav>
    <!--首页附近商家-->
    <div class="msite_shop_list">
      <div class="shop_header">
        <i class="iconfont icon-xuanxiang"></i>
        <span class="shop_header_title">附近商家</span>
      </div>
      <ShopList/>
    </div>
  </section>
</template>
<script>
//使用HeaderTop组建
//第一步 先导

import {mapState} from 'vuex' //引入读管理状态  必须引入一个vuex的映射函数
import Swiper from 'swiper'   //导入Swiper  用来写轮播图的插件
import 'swiper/dist/css/swiper.min.css'    //引入样式  保证nav的类名按照 swiper 的类名来写

import HeaderTop from '../../components/HeaderTop/HeaderTop.vue'
import ShopList from '../../components/ShopList/ShopList.vue'
  

export default {
 data () {
      return {
        baseImageUrl: 'https://fuss10.elemecdn.com'
      }
    },
  mounted () {
    
    this.$store.dispatch('getCategorys') //获取数据  同时存储数据到浏览器内存  括号里是action名字
    this.$store.dispatch('getShops')
//     第二步  读数据 
// 创建一个Swiper实例对象   来实现轮播
    new Swiper('.swiper-container', {
      loop: true, // 循环模式选项
      // 如果需要分页器
      pagination: {
        el: '.swiper-pagination',
      },
    })
},
 
  //第二步映射成标签
  components:{
    HeaderTop,
    ShopList,
  },
  
  //第三步使用
     computed:{
      ...mapState(['address','categorys','userInfo']),    //读管理状态的映射
      /*
      根据categorys一维数组生成一个2维数组
      小数组中的元素个数最大是8
       */
      categorysArr () {
        const {categorys} = this
        // 准备空的2维数组
        const arr = []
        // 准备一个小数组(最大长度为8)
        let minArr = []
        // 遍历categorys
        categorys.forEach(c => {
          // 如果当前小数组已经满了, 创建一个新的
          if(minArr.length===8) {
            minArr = []
          }
          // 如果minArr是空的, 将小数组保存到大数组中
          if(minArr.length===0) {
            arr.push(minArr)
          }
          // 将当前分类保存到小数组中
          minArr.push(c)
        })

        return arr
      }
    },
    watch: {
      categorys (value) { // categorys数组中有数据了, 在异步更新界面之前执行
        // 使用setTimeout可以实现效果, 但不是太好   影响性能 自定义刷新时间 
        //需要监听页面刷新时间 让界面一刷新就能监听 然后创建swiper
        /*setTimeout(() => {
          // 创建一个Swiper实例对象, 来实现轮播
          new Swiper('.swiper-container', {
            loop: true, // 可以循环轮播
            // 如果需要分页器
            pagination: {
              el: '.swiper-pagination',
            },
          })
        }, 100)*/

        // 界面更新就立即创建Swiper对象
        this.$nextTick(() => {// 一旦完成界面更新, 立即调用(此条语句要写在数据更新之后)
          // 创建一个Swiper实例对象, 来实现轮播
          new Swiper('.swiper-container', {
            loop: true, // 可以循环轮播
            // 如果需要分页器
            pagination: {
              el: '.swiper-pagination',
            },
          })

         
        })

      }
    },
}
</script>
<style lang="stylus" rel="stylesheet/stylus">
@import "../../common/stylus/mixins.styl";
.msite  //首页
  width 100%
    .header_login
      font-size 14px
      color #fff
      position absolute
      right 15px
      top 50%
      transform translateY(-50%)
      .header_login_text
        color #fff
  .msite_nav
    bottom-border-1px(#e4e4e4)
    margin-top 45px
    height 200px
    background #fff
    .swiper-container
      width 100%
      height 100%
      .swiper-wrapper
        width 100%
        height 100%
        .swiper-slide
          display flex
          justify-content center
          align-items flex-start
          flex-wrap wrap
          .link_to_food
            width 25%
            .food_container
              display block
              width 100%
              text-align center
              padding-bottom 10px
              font-size 0
              img
                display inline-block
                width 50px
                height 50px
            span
              display block
              width 100%
              text-align center
              font-size 13px
              color #666
      .swiper-pagination
        >span.swiper-pagination-bullet-active
          background #02a774
</style>